草庐IT

c++ - std::byte 的用例

全部标签

c - Go 语言使用 C 的内部结构

我希望能够在Go中将一个主机地址(让我们使用“www.google.be”)转换为sockaddr结构,然后在C代码中使用它。使用http://github.com/jbenet/go-sockaddr将主机地址转换为sockaddr_any结构并不难模块。我的代码有效,如下所示:ipAddr,_:=net.ResolveIPAddr("ip","www.google.be")sockAddr:=sockaddrnet.IPAddrToSockaddr(ipAddr)rawSockaddr,socklen,_:=sockaddr.SockaddrToAny(sockAddr)cStru

CGO 我正在传递一个 C 结构,它带有一个指向 go 函数的值的指针,

我很疑惑下面的场景是否需要清理内存?我有一个C函数,它创建一个C结构并将其传递给Go函数。C结构包含一个值数组(使用指针算法)。Go函数填充此数组并返回。在调用C函数中,我将值从C结构中复制出来并且不存储它们。因为这是在Go中创建的,所以垃圾会被收集吗?/*Ccode*/intgo_func(c_struct*s);structc_struct{val*values;size_t*values_cnt;};voidexample_call(){structc_structs;go_func(&s)copy_values(s)}/*gocode*/funcgo_func(c*C.c_st

无法访问cgo中的c变量

我正在尝试访问cgo中的c结构,但是请执行此操作couldnotdeterminekindofnameforC.utmpxutmpx是一个C结构体这是执行代码:/*#include#include#include#include#include*/import"C"typerecordC.utmpxfd,err:=os.Open(C._PATH_UTMPX)//thisworksfd,err:=os.Open(C.UTMPX_FILE)//error在utmpx.h文件中,有#define_PATH_UTMPX"/var/run/utmpx"#defineUTMPX_FILE_PATH

c - 求和,数组构造和寻址的简洁二叉树

使用“sum”作为捷径进行任意计算。我有一个通过递归求和值对来从值列表中计算单个和的过程。未配对的值将被不变地提升到树上,直到可以配对为止。在进行了这种计算之后,我正在寻找平衡计算的最佳方法(即访问数组元素/节点所需的操作数)以及一维数组中所有节点的最简洁的编码(即无间隙,零值)(或重复值),并且最好没有额外的索引数组,该数组不能从简洁编码中轻松得出,因此必须将其与数组一起保存。尽管以下是简单的示例,但实际上,初始列表中的值数量可能非常大(2^47或更多)。例如,给定列表[1、2、3、4],该数组是微不足道的:[10、3、7、1、2、3、4],并很好地拆分为易于按节点寻址的行,或作为对

c - "Undefined symbols for architecture x86_64:"用于在 macOS Sierra 上使用 cgo 的库

我正在尝试使用图书馆,https://github.com/go-steem/rpc,它使用了一些引用库的C代码。C库可以在这里找到,https://github.com/bitcoin-core/secp256k1我按照步骤安装了它$./autogen.sh$./configure$make$./tests$sudomakeinstall#optional并有这个输出;$sudomakeinstallPassword:CCsrc/libsecp256k1_la-secp256k1.loCCLDlibsecp256k1.laCCsrc/tests-tests.oCCLDtestsCCs

c - 尝试在 Windows 上使用 cuda

有各种依赖于cuda.h文件和cuda库(特别是ML库)的Go库。每次我尝试在Windows上安装这些库之一时,我都会收到一条错误消息fatalerror:cuda.h:Nosuchfileordirectory//#include我知道我需要做什么(将Cuda库/头文件链接到我要安装的go库),但是,我不确定如何去做,尤其是在Windows上。由于各种原因,我使用GCC而不是MSVC,但即使我尝试使用MSVC,我也遇到了同样的问题。有什么方法可以将cuda编译器/头文件直接链接到我的Go环境,或者我是否需要手动将go/cgo编译器指向保存Cuda头文件的目录,我该怎么做?我试过向一些

go - 如何在golang中将ascii码转换为byte?

正如标题所说,我可以找到给我字节ascii码的函数,但反之则不行 最佳答案 Golang字符串文字是UTF-8,因为ASCII是UTF-8的子集,并且它的每个字符只有7位,我们可以很容易地通过强制转换将它们作为字节获取(例如bytes:=[]字节(字符串):packagemainimport"fmt"funcmain(){asciiStr:="ABC"asciiBytes:=[]byte(asciiStr)fmt.Printf("OK:string=%v,bytes=%v\n",asciiStr,asciiBytes)fmt.Pri

go - 序列化结构字段以预先存在 byte slice

我有一个设置,可以通过网络接收数据并将其序列化到我的结构中。它工作正常,但现在我需要将数据序列化到slice缓冲区以通过网络发送它。我试图避免分配超过需要的空间,所以我已经设置了一个缓冲区,我想为我的所有序列化写入该缓冲区。但我不确定该怎么做。我的设置是这样的:recieveBuffer:=make([]byte,1500)header:=recieveBuffer[0:1]message:=recieveBuffer[1:]因此,我尝试将结构中的字段写入message,并将所有字段的总字节数作为header的值。这就是我反序列化结构的方式://Deserialize...func(u

c++ - 如何将 CGO 用于具有条件内联函数的头文件?

我目前正在为Capi编写一个Go包装器,其中包含带有此ifdef的header:#ifdef__cplusplus#defineTEST_INLINEinline#else#defineTEST_INLINE#endifTEST_INLINEintcallC_inline(){return1;}不幸的是,我无法更改header,因为它是第三方代码。如果我将-Wl,--allow-multiple-definition传递给链接器,代码可以正常编译,但我认为这是一种不好的做法。所以,我感兴趣的是有没有我可以传递给CGO的标志或技巧来满足#ifdef__cplusplus条件?编译异常:C

go - bytes.Buffer ReadFrom 与 r.Read 不同?

在连接错误的情况下,我想从ioReader获取数据流并在通过httppost将其作为流发送之前对其进行缓冲。为此,我计划使用bytes.Buffer并将其从读取器复制到缓冲区。一个单独的goroutine将从缓冲区读取并将读取器传递给http.Request。现在,bytes.BufferReadFrom的行为不是我所期望的。我正在用管道模拟数据流:r,w:=io.Pipe()gofunc(){fori:=0;i当从读取器读取byteslice时,每次写入后Read返回,但是,当使用ReadFrom时,它不会停止读取直到写入器关闭。这:buf:=&bytes.Buffer{}nIn,e